<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>jsx语法规则</title>
</head>

<body>
    <div id="test"></div>
    <div id="demo"></div>
    <script type="text/javascript" src="../js/react.development.js"></script>
    <script type="text/javascript" src="../js/react-dom.development.js"></script>
    <script type="text/javascript" src="../js/babel.min.js"></script>
    <script type="text/babel">
        const myId = 'TITLE';
        const myData = 'Hello，React';
        const VDOM = (
            <div>
                <h1 className="title" id={myId.toLocaleLowerCase()}>
                    <span style={{ background: 'orange' }}>
                        {myData.toLocaleLowerCase()}
                    </span>
                </h1>
                <h1 className="title" id={myId}>
                    <span style={{ background: 'orange' }}>
                        {myData.toLocaleLowerCase()}
                    </span>
                </h1>
                <input type="text" />
                {/* <good>good</good> */}
                {/* <Good>good</Good> */}
            </div>
        );
        ReactDOM.render(VDOM, document.getElementById('test'));
        /**
         * JSX语法规则：
         * 1.定义虚拟DOM时，不要写引号；
         * 2.标签中混入JS表达式时要用{}包裹；
         * 3.样式的类名指定不要用class，要用className（class在es6中是关键字类）；
         * 4.内联样式，要用style={{key:value}}的形式；
         * 5.虚拟DOM只能有一个根标签；
         * 6.标签必须闭合；
         * 7.标签首字母
         *   a.若小写字母开头，则将标签转为html中同名元素，若html中无该标签对应的同名元素，则报错；
         *   b.若大写字母开头，react就去渲染对应的组件，若组件没有定义，则报错；
         */
    </script>
</body>

</html>